草庐IT

c++ - 机器 Epsilon 精度差异

全部标签

Ruby 浮点精度

据我了解,Ruby(1.9.2)float的精度为15位十进制数字。因此,我希望将floatx舍入到小数点后15位将等于x。对于此计算,情况并非如此。x=(0.33*10)x==x.round(15)#=>false顺便说一句,四舍五入到16位返回true。你能给我解释一下吗? 最佳答案 部分问题是0.33在底层格式中没有精确的表示,因为它不能用一系列1/2n项来表示。因此,当它乘以10时,乘以的数字与0.33略有不同。就此而言,3.3也没有精确表示。第一部分当数字没有精确的10进制表示时,在转换尾数中有信息的最低有效位时会有余数。

Windows 7 64 位机器上的 Ruby 安装程序

任何人都可以帮我在哪里找到要在Windows7上安装的Ruby64位安装程序,或者我可以在64位机器上安装32位Ruby1.8.6或1.9安装程序(只有一个)没有任何问题吗?.任何建议或文档链接将不胜感激。提前致谢。 最佳答案 由于WOW64(WindowsonWindows功能),32位Ruby可以安装在64位Windows版本中64位Ruby没有安装程序,您会发现这方面有很多复杂的问题。我建议您使用官方RubyInstaller网站上即将推出的RubyInstallers:http://rubyinstaller.org/(将被

ruby-on-rails - 如何查看我机器上安装的 gem 的源代码?

我在我的Rails应用程序中安装了Devise,我想通读源代码并了解它是如何工作的。我查看了我的Rails应用程序的整个文件夹结构,但找不到任何代码(方法调用除外)。我知道我可以从Github存储库中看到源代码,但我希望在我的编辑器和本地计算机上看到它。我猜这段代码一定在某个主要的Ruby目录中,但我找不到它。任何帮助表示赞赏。谢谢。 最佳答案 除了Sergio的建议,还有另一种选择。在你的Rails路径中$bundleopendevise这将使用Gemfile中指定的版本在编辑器中打开已安装的gem,非常方便。

c - 命令行错误消息的 "POSIX-defined format"是什么?哪个标准?

在ruby​​-doc.org上page我发现了以下关于命令行选项/参数解析(getopt库)的内容:ReturntheappropriateerrormessageinPOSIX-definedformat.Ifnoerrorhasoccurred,returnsnil.命令行错误消息的POSIX定义格式是什么?它是哪个POSIX标准?编辑:我必须澄清一下,我对标准/推荐的错误消息很感兴趣解析命令行参数/选项。在下面的链接(答案)中,我发现只提到了getopt的这种错误格式:"%s:illegaloption--%c\n",,"%s:optionrequiresanargument-

c - 在不使用其他功能的情况下释放 C 扩展中的全局 VM 锁

我不明白为什么在发布或获取RubyCAPI中的GVL时需要另一个间接级别。rb_thread_call_without_gvl()和rb_thread_call_with_gvl()都需要一个只接受一个参数的函数,但情况并非总是如此。我不想仅仅为了发布GVL而将我的参数包装在一个结构中。它使代码的可读性变得复杂,并且需要从void指针转换到void指针。在查看Ruby的线程代码后,我找到了GVL_UNLOCK_BEGIN。/GVL_UNLOCK_END与Python的Py_BEGIN_ALLOW_THREADS/Py_END_ALLOW_THREADS匹配的宏但我找不到关于它们以及何时

c - Ruby 解释器的嵌入 API 的文档在哪里?

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。关闭5年前。Improvethisquestion我正在寻找有关将Ruby解释器嵌入到C或C++程序以及用于该目的的API的全面的在线文档资源。Pickaxe书中关于此的部分非常好,但我的版本指的是Ruby1.8,我对当前的ruby​​版本范围很感兴趣,即1.8.x、1.9.x和2.0,并且有很多跨该版本范围的嵌入处理之间的差异。作为引用,有问题的Ruby解释器是来自http://www.ruby-lang.org/

ruby - 如何使用 Ansible 在 Ubuntu 机器上安装 Ruby 2 和 Ruby Gems

我想使用Ansible为Ubuntu服务器机器配置最新的Ruby和RubyGems版本。p>我该怎么做? 最佳答案 解决方案#1:使用APT和符号链接(symboliclink)如果可以全局安装Ruby2.0和RubyGems(对于所有用户),我建议使用此解决方案。如果您想安装另一个版本或将其与其他用户隔离-请参阅解决方案#2。这是一个简单的Ansible剧本,它将为您安装最新的Ruby2.0和RubyGems:Ubuntu14.04(TrustyTahr)-name:LatestversionofRubyisinstalledap

c - Ruby C 扩展开发人员的命名约定

在用C为ruby​​编写扩展时,我对遵循正确的命名约定很感兴趣。具体来说,我指的是将_p添加到谓词的函数名称以及为变量添加前缀m代表模块,c代表类等等。例如,如果我们想在C语言中定义一个像下面这样的谓词方法,我们应该在定义该方法的函数中使用_p作为后缀。classMyClassdefawesome?trueendend在C中:staticVALUEmy_extension_my_class_awesome_p(VALUEself){returnQtrue;}voidInit_my_extension(void){VALUEcMyClass=rb_define_class("MyClas

ruby - 如何以两位数的精度显示输出

这是我的代码classAtmattr_accessor:amount,:rem,:balanceTAX=0.50deftransaction@rem=@balance=2000.00@amount=gets.chomp.to_fif@amount%5!=0||@balance我的输出是Enteramountfortransaction100#userentersthisvalueSuccessfulTransactionYourbalanceis1899.5如您所见,“您的余额为1899.5”的输出仅显示一位精度。我需要帮助来理解和解决问题。我希望输出有两位数的精度。还有我该如何改进这

ruby - ruby 中的机器学习算法

我正在关注StanfordMachineLearningclass与教授。AndrewNg和我想开始用ruby​​实现示例。是否有任何框架/gems/libs/现有代码可以在ruby​​中实现机器学习?我发现了一些与此和一些项目相关的问题,但似乎已经很老了。 最佳答案 算法本身不是特定于语言的。您可以使用任何您想要的语言来实现它们。为了获得最大效率,您将需要使用基于矩阵/向量的计算。Ruby有一个内置的Matrixclass可以用来实现这些算法。该实现与使用Octave的实现非常相似。您自己实现算法所需的一切都包含在1.9+的基本标